> ÖMER FARUK ÖZDEMİR SECTİON: FF12 MUSTAFA FATİH KURT GROUP ID: 6

## **CMPE 240 2018 Experiment 4 Preliminary Work**

(For illustrations you can use any drawing tool that you want including Microsoft Word Shapes. Do not use scanned images of hand drawn state machines and architecture diagrams.)

(For tables please use insert table feature of Microsoft Word)

Step 1: Capture the FSM: Create and draw the finite state machine that describes the desired behavior of the controller.



Step 2: Create the architecture: Create and draw standard architecture by a using state register of the appropriate width and combinational logic. Refer to book or lecture slides. Use the same convention.



Step 3: Encode the states: Assign a unique binary number to each state. Each binary number representing a state is known as an encoding. Any encoding will do as long as each state has a unique encoding. (The content of the following table is an example. Rename the states according to the ones you specified in the first section. Also use any encoding you want.)

| STATE NAME | ENCODING |
|------------|----------|
| WAIT       | 000      |
| START      | 001      |
| BW         | 010      |
| BWW        | 011      |
| BWWW       | 100      |
| BWB        | 101      |
| BB         | 110      |
| DON'T CARE | 111      |

| - 24 | A  | В  | С   | D  | E   | F  | G  | Н  | Î  | j  |      | K | L | M        | N                                  | 0 | P   | Q | R      | S  | T  |   |
|------|----|----|-----|----|-----|----|----|----|----|----|------|---|---|----------|------------------------------------|---|-----|---|--------|----|----|---|
| 1    |    | 52 | \$1 | 50 | ı   | N2 | N1 | NO | 01 | 00 |      |   |   |          |                                    | 1 |     |   | Output | 01 | 00 |   |
| 2    | 0  |    |     |    | 0   | 0  | 0  | 0  | 1  | 1  | 0 -  |   |   | WAIT     | 0,0,0                              |   | 0 B |   | (      | )  | 0  | 0 |
| 3    | 1  |    |     |    | O O | 1  | 0  | 0  | 0  | 1  | 0 -  |   |   | START    | 0,0,1                              |   | 1 W |   | 1      | 1  | 0  | 1 |
| 4    | 2  |    |     |    | 1   | 0  | 1  | 1  | 0  | 1  | 0 -  |   |   | BW-      | 0,1,0                              |   |     |   | 27     |    | 1  | 0 |
| 5    | 3  |    |     |    | 1   | 1  | 0  | 1  | 0  | 1  | 0 -  |   |   | BWW      | 0,1,1                              |   |     |   | end    |    | 1  | 1 |
| 6    | 4  |    |     |    | 0   | 0  | 1  | 0  | 1  | 1  | 0 -  |   |   | BWWW     | 1,0,0                              |   |     |   |        |    |    |   |
| 7    | 5  |    |     |    | Ó   | 1  | 0  | 1  | 1  | 1  | 0 -  |   |   | BWB      | 1,0,1                              |   |     |   |        |    |    |   |
| 8    | 6  |    |     |    | 1   | 0  | 0  | 0  | 1  | 1  | 0 -  |   |   | BB       | 1,1,0                              |   |     |   |        |    |    |   |
| 9    | 7  |    |     |    | 4   | 1  | 1  | 0  | 0  | 1  | 0 -  |   |   | DONTCARE | 1,1,1                              |   |     |   |        |    |    |   |
| 10   | 8  | Ц  |     |    | 0   | 0  | 0  | 0  | 1  | 0  | 1    | 1 |   |          |                                    |   |     |   |        |    |    |   |
| 11   | 9  |    |     |    | O . | 1  | 0  | 0  | 0  | 0  | 1    | 1 |   | 00       | S2S0'                              |   |     |   |        |    |    |   |
| 12   | 10 |    |     |    | 1   | 0  | 1  | 1  | 0  | 0  | 0    | 0 |   | 01       | S2'+S1                             |   |     |   |        |    | Ī  |   |
| 13   | 11 |    |     |    | 4   | 1  | 0  | 1  | 0  | 0  | 0    | 0 |   | NO       | .50'I'+\$2'\$1\$0'+\$2'\$1I'       |   |     |   |        |    |    |   |
| 14   | 12 |    |     |    | 0   | 0  | 0  | 0  | 1  | 1  | 1 en | d |   | N1       | S2'S1'S0+S1S0I'+S2'S1S0'I+S1'S0I   |   |     |   |        |    |    |   |
| 15   | 13 |    |     |    | Ó   | 1  | 0  | 0  | 0  | 1  | 1 en | d |   | N2       | \$1'\$0 '+\$2'\$1\$0' '+\$2'\$1\$0 |   |     |   |        |    |    |   |
| 16   | 14 |    | 1   | 1  | 1   |    | 0  | 0  | 0  | 1  | 0 -  |   |   |          |                                    |   |     |   |        |    |    |   |
| 17   | 15 |    | 1   | 1  | 1   |    | 0  | 0  | 0  | 1  | 0 -  |   |   |          |                                    |   |     |   |        |    |    |   |

Step 4: Create the state table: Create a truth table for the combinational logic such that the logic will generate the correct FSM outputs and next state signals. Ordering the inputs with state bits first makes this truth table describe the state behavior, so the table is a state table. (Update the table according to the number of state variables that you have used.)

| CURRENT<br>STATE | INPUTS | NEXT STATE | OUTPUTS |  |  |
|------------------|--------|------------|---------|--|--|
| WAIT             | В      | START      | -       |  |  |
| WAIT             | W      | WAIT       | -       |  |  |
| START            | В      | BB         | -       |  |  |
| START            | W      | BW         | -       |  |  |
| BW               | В      | BWB        | -       |  |  |
| BW               | W      | BWW        | -       |  |  |
| BWW              | В      | START      | -       |  |  |
| BWW              | W      | BWWW       | -       |  |  |
| BWWW             | В      | START      | 1       |  |  |
| BWWW             | W      | WAIT       | 1       |  |  |
| BWB              | В      | BB         | 0       |  |  |
| BWB              | W      | WAIT       | 0       |  |  |
| BB               | В      | START      | End     |  |  |
| BB               | W      | WAIT       | End     |  |  |
| DON'T CARE       | В      | WAIT       | -       |  |  |
| DON'T CARE       | W      | WAIT       | -       |  |  |

Step 5: Draw the combinational logic: Implement the combinatorial logic using any method (You do not need to draw the inside circuit of multiplexers or decoders if you are using any. You can show those as blocks).

